// Copyright (c) 2025, 大连理工大学 (Dalian University of Technology)
//
// Licensed under the Mulan PSL v2.
// You can use this file according to the terms and conditions of the Mulan PSL v2.
// You may obtain a copy of the License at
//
//     http://license.coscl.org.cn/MulanPSL2
//
// THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
// EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. SEE THE MULAN PSL v2
// FOR MORE DETAILS.

#include "Import/BDFImport/BulkData/Load/TLOAD1Parser.h"

#include "gtest/gtest.h"

#include "DataStructure/Common/Constant.h"
#include "DataStructure/Input/Load/TLOAD1Data.h"

#include "DBManager/DBServiceFactory.h"
#include "DBManager/IService/Input/Load/ITLOAD1Service.h"

#include "Import/BDFImport/BDFParserBase.h"
using namespace SG::DBManager;
using namespace SG::Import;

using SG::DataStructure::Common::TOLERANCE;
using namespace SG::DataStructure::FEM;
extern std::shared_ptr<DBServiceFactory> DB_SERVICEFACTORY;
extern std::vector<std::string>          dividedEntryInfo;

class TLOAD1ParserTest : public ::testing::Test
{
  public:
    static void SetUpTestSuite ()
    {
        DB_SERVICEFACTORY->ClearDatabase ();
    }
};

TEST_F (TLOAD1ParserTest, ParseEntry1)
{
    std::vector<std::string> Entry = { "TLOAD1   6       7                       1" };
    BDF::divideBulkEntry (Entry, dividedEntryInfo);
    SG::Import::BDF::BULKDATA::ParseTLOAD1 (DB_SERVICEFACTORY, dividedEntryInfo);
    std::vector<SG::DataStructure::FEM::TLOAD1Data> TLOAD1s;

    SG::DataStructure::FEM::TLOAD1Data data;

    DB_SERVICEFACTORY->get<ITLOAD1Service> ()->FindBySId (6, TLOAD1s);

    data = TLOAD1s[0];

    ASSERT_TRUE (data.m_sId == 6);
    ASSERT_TRUE (data.m_DAREA == 7);
    ASSERT_TRUE (data.m_DELAY == 0);
    ASSERT_TRUE (data.m_TID == 1);
    ASSERT_TRUE (data.m_TYPE == 0);
    ASSERT_NEAR (data.m_T, 0.0, TOLERANCE);
    ASSERT_NEAR (data.m_U0, 0.0, TOLERANCE);
    ASSERT_NEAR (data.m_V0, 0.0, TOLERANCE);
    ASSERT_NEAR (data.m_F, 0.0, TOLERANCE);
}
